<?php
// Load the Qcodo Development Framework
require('../includes/prepend.inc.php');

/**
 * This is a quick-and-dirty draft QForm object to do Create, Edit, and Delete functionality
 * of the Peopledetails class.  It uses the code-generated
 * PeopledetailsMetaControl class, which has meta-methods to help with
 * easily creating/defining controls to modify the fields of a Peopledetails columns.
 *
 * Any display customizations and presentation-tier logic can be implemented
 * here by overriding existing or implementing new methods, properties and variables.
 *
 * NOTE: This file is overwritten on any code regenerations.  If you want to make
 * permanent changes, it is STRONGLY RECOMMENDED to move both peopledetails_edit.php AND
 * peopledetails_edit.tpl.php out of this Form Drafts directory.
 *
 * @package My Application
 * @subpackage Drafts
 */
class PeopledetailsEditForm extends QForm {
	// Local instance of the PeopledetailsMetaControl
	protected $mctPeopledetails;

	// Controls for Peopledetails's Data Fields
	protected $lblId;
	protected $txtFullName;
	protected $txtAddress;
	protected $txtPhone;
	protected $txtEmail;

	// Other ListBoxes (if applicable) via Unique ReverseReferences and ManyToMany References

	// Other Controls
	protected $btnSave;
	protected $btnDelete;
	protected $btnCancel;

	// Create QForm Event Handlers as Needed

	//		protected function Form_Exit() {}
	//		protected function Form_Load() {}
	//		protected function Form_PreRender() {}

	protected function Form_Run() {
		// Security check for ALLOW_REMOTE_ADMIN
		// To allow access REGARDLESS of ALLOW_REMOTE_ADMIN, simply remove the line below
		QApplication::CheckRemoteAdmin();
	}

	protected function Form_Create() {
		// Use the CreateFromPathInfo shortcut (this can also be done manually using the PeopledetailsMetaControl constructor)
		// MAKE SURE we specify "$this" as the MetaControl's (and thus all subsequent controls') parent
		$this->mctPeopledetails = PeopledetailsMetaControl::CreateFromPathInfo($this);

		// Call MetaControl's methods to create qcontrols based on Peopledetails's data fields
		$this->lblId = $this->mctPeopledetails->lblId_Create();
		$this->txtFullName = $this->mctPeopledetails->txtFullName_Create();
		$this->txtAddress = $this->mctPeopledetails->txtAddress_Create();
		$this->txtPhone = $this->mctPeopledetails->txtPhone_Create();
		$this->txtEmail = $this->mctPeopledetails->txtEmail_Create();

		// Create Buttons and Actions on this Form
		$this->btnSave = new QButton($this);
		$this->btnSave->Text = QApplication::Translate('Save');
		$this->btnSave->AddAction(new QClickEvent(), new QServerAction('btnSave_Click'));
		$this->btnSave->CausesValidation = true;

		$this->btnCancel = new QButton($this);
		$this->btnCancel->Text = QApplication::Translate('Cancel');
		$this->btnCancel->AddAction(new QClickEvent(), new QServerAction('btnCancel_Click'));

		$this->btnDelete = new QButton($this);
		$this->btnDelete->Text = QApplication::Translate('Delete');
		$this->btnDelete->AddAction(new QClickEvent(), new QConfirmAction(QApplication::Translate('Are you SURE you want to DELETE this') . ' ' . QApplication::Translate('Contact') . '?'));
		$this->btnDelete->AddAction(new QClickEvent(), new QServerAction('btnDelete_Click'));
		$this->btnDelete->Visible = $this->mctPeopledetails->EditMode;
	}

	/**
	 * This Form_Validate event handler allows you to specify any custom Form Validation rules.
	 * It will also Blink() on all invalid controls, as well as Focus() on the top-most invalid control.
	 */
	protected function Form_Validate() {
		// By default, we report that Custom Validations passed
		$blnToReturn = true;

		// Custom Validation Rules
		// TODO: Be sure to set $blnToReturn to false if any custom validation fails!

		$blnFocused = false;
		foreach ($this->GetErrorControls() as $objControl) {
			// Set Focus to the top-most invalid control
			if (!$blnFocused) {
				$objControl->Focus();
				$blnFocused = true;
			}

			// Blink on ALL invalid controls
			$objControl->Blink();
		}

		return $blnToReturn;
	}

	// Button Event Handlers

	protected function btnSave_Click($strFormId, $strControlId, $strParameter) {
		// Delegate "Save" processing to the PeopledetailsMetaControl
		$this->mctPeopledetails->SavePeopledetails();
		$this->RedirectToListPage();
	}

	protected function btnDelete_Click($strFormId, $strControlId, $strParameter) {
		// Delegate "Delete" processing to the PeopledetailsMetaControl
		$this->mctPeopledetails->DeletePeopledetails();
		$this->RedirectToListPage();
	}

	protected function btnCancel_Click($strFormId, $strControlId, $strParameter)
	{
			
		$this->RedirectToListPage();
	}

	// Other Methods

	protected function RedirectToListPage()
	{
		QApplication::Redirect('../peopledetails_list.php');
	}
}

// Go ahead and run this form object to render the page and its event handlers, implicitly using
// peopledetails_edit.tpl.php as the included HTML template file
PeopledetailsEditForm::Run('PeopledetailsEditForm');
?>